package com.ychen.goods.dao;

import org.springframework.data.mongodb.core.MongoTemplate;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.core.query.Update;

import java.util.List;

public interface BaseDao<T> {
    void save(T bean);

    // 根据id删除对象
    void deleteById(T t);

    // 根据对象的属性删除
    void deleteByCondition(T t);

    // 通过条件查询更新数据
    void update(Query query, Update update);

    // 根据id进行更新
    void updateById(String id, T t);

    // 通过条件查询实体(集合)
    List<T> find(Query query);

    List<T> findByCondition(T t);

    // 通过一定的条件查询一个实体
    T findOne(Query query);


    // 通过ID获取记录
    T findById(String id);

    // 通过ID获取记录,并且指定了集合名(表的意思)
    T findById(String id, String collectionName);

    MongoTemplate getMongoTemplate();

}
